8375
4760
Jeg lurte på, forsinker mellomrom og kommentarer JavaScript? Jeg gjør et voldsomt angrep som tar litt tid (30 sekunder). Fjerning av mellomrom viser ikke en betydelig vekst i hastighet, men jeg tror nettleseren bare må analysere mer.
Så er det til nytte å fjerne unødvendige mellomrom og kommentarer for å øke hastigheten? 
Folk bruker vanligvis minimizer for å redusere STØRRELSEN på skriptet, for å forbedre nedlastingshastigheten, i stedet for å gjøre noen forskjell i hastigheten på å analysere skriptet.
Hvit mellomrom og kommentarer vil ha liten effekt i hvor lang tid det tar en nettleser å utføre, ettersom parseren trenger å sjekke om det er hvitt mellomrom, eller en kommentar, men i virkeligheten vil dette være så lite med dagens datakraft, det ville være umulig å merke til påvirkning.
STØRRELSE er imidlertid fortsatt viktig selv med den store båndbredden som er tilgjengelig i vår bredbåndsverden.
|
Mellomrom og kommentarer øker størrelsen på JavaScript-filen, noe som reduserer den faktiske nedlastingen av filen fra serveren - minifisering er prosessen med å fjerne unødvendige tegn fra en JavaScript-fil for å gjøre den mindre og enklere å laste ned.
Siden du nevner et voldsomt angrep, er flaskehalsen sannsynligvis ikke nedlastingen. Prøv å bruke en profil for å finne det som bremser deg.
|
Det er alltid et poeng i å minifisere, kombinere og gzippe eiendelene dine for å lette serverbelastningen.
Minifisering er handlingen du refererer til, for å fjerne unødvendig mellomrom og kommentarer for å gjøre nedlastingshastigheten mindre.
Kombinering vil mest sannsynlig vise en enda større økning i sidegjenvinningshastighet; det handler om å slå sammen alle javascript-filene dine til en og alle css-filene dine til en (det kan også gjøres for de fleste bilder, men det krever at du tar mer arbeid). Dette gjøres for å redusere antall forespørsler nettleseren må stille til serveren din, for å kunne vise siden.
GZipping er handlingen med å komprimere dataene i et zippet format til nettleserne som indikerer at de godtar slike data. Dette reduserer størrelsen ytterligere, men gir litt ekstra arbeidsbelastning i begge ender. Du vil sannsynligvis se en nettovinst på det.
Avhengig av hvilket miljø du jobber i, er det forskjellige komponenter som vil hjelpe deg med dette, som vanligvis dekker alle de ovennevnte på en gang.
Tiden det tar å laste ned koden fra serveren har en direkte innvirkning på hvor lang tid det tar å gjengi siden. JavaScript blokkerer, noe som betyr at en JS-blokk forhindrer lengre gjengivelse, til blokken er utført helt. Som sådan, hvor du legger javascript-filene dine (dvs. i hvilket punkt i gjengivelsesprosessen de blir bedt om), hvor mange forespørsler som trengs for å bli fullstendig lastet ned, og hvor mye data det er å laste ned, vil ha innvirkning på siden du laster inn, slik det ser ut til brukeren.
Når nettleseren har analysert koden din, det være seg javascript, css eller html, vil den ha opprettet interne representasjoner av delen den trenger for å huske, og den faktiske formateringen vil ikke lenger påvirke den.
|
Jeg tror ikke at mellomrom i js-kode bremser utførelsen av den. Så vidt jeg forstår striper en javascript-tolk alle kommentarer og overflødig mellomrom før behandlingen. Det kan imidlertid påvirke nedlastingstid og dermed lastetid på en webside.
Ta en titt her for litt ekstra informasjon.
|
Det har liten eller ingen innvirkning på faktisk behandlingshastighet, men ...
Mindre størrelse => mindre båndbredde => mindre kostnader => ??? => fortjeneste!
|
Ditt svar
StackExchange.ifUsing ("editor", function () {
StackExchange.using ("externalEditor", funksjon () {
StackExchange.using ("snippets", function () {
StackExchange.snippets.init ();
});
});
}, "kodebiter");
StackExchange.ready (funksjon () {
var channelOptions = {
tagger: "" .split (""),
id: "1"
};
initTagRenderer ("". split (""), "" .split (""), channelOptions);
StackExchange.using ("externalEditor", funksjon () {
// Må utløse redaktøren etter utdrag, hvis utdrag er aktivert
hvis (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using ("snippets", function () {
createEditor ();
});
}
annet {
createEditor ();
}
});
funksjon createEditor () {
StackExchange.prepareEditor ({
useStacksEditor: false,
hjerteslagType: 'svar',
autoActivateHeartbeat: false,
convertImagesToLinks: sant,
noModals: sant,
showLowRepImageUploadWarning: true,
reputToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Drevet av \ u003ca href = \" https: //imgur.com/ \ "\ u003e \ u003csvg class = \" svg-icon \ "width = \" 50 \ "height = \" 18 \ "viewBox = \ "0 0 50 18 \" fill = \ "none \" xmlns = \ "http: //www.w3.org/2000/svg \" \ u003e \ u003cpath d = \ "M46.1709 9.17788C46.1709 8.26454 46.2665 7.94324 47.1084 7.58816C47.4091 7.46349 47.7169 7.36433 48.0099 7.26993C48.9099 6.97997 49.672 6.73443 49.672 5.93063C49.672 5.22043 48.9832 4.61182 48.1414 4.61182C47.4335 4.61182 46.7256 4.916 43.1481 6.59048V11.9512C43.1481 13.2535 43.6264 13.8962 44.6595 13.8962C45.6924 13.8962 46.1709 13.2535 46.1709 11.9512V9.17788Z \ "/ \ u003e \ u003cpath d = \" M32.492 10.1419C4.4.014.412 12.6 12.6 41.5985 12.6954 41.5985 10.1419V6.59049C41.5985 5.28821 41.1394 4.6623240.1061 4.66232C39.0732 4.66232 38.5948 5.28821 38.5948 6.59049V9.60062C38.5948 10.8521 38.2696 11.5455 37.0451 11.5455C35.8209 11.5455 35.4954 10.8521 35.4954 9.60062V6.59049C35.4953.466 "/ \ u003e \ u003cpath fill-rule = \" evenodd \ "clip-rule = \" evenodd \ "d = \" M25.6622 17.6335C27.8049 17.6335 29.3739 16.9402 30.2537 15.6379C30.8468 14.7755 30.9615 13.5579 30.9615 11.95126. 59049C30.9615 5.28821 30.4833 4.66231 29.4502 4.66231C28.9913 4.66231 28.4555 4.94978 28.1109 5.50789C27.499 4.86533 26.7335 4.56087 25.7005 4.56087C23.1369 4.56087 21.0134 6.57349 21.0134 9.2432.921.213 1109 12.7229 28.1161 12.7799 28.121 12.8346C28.1256 12.8854 28.1301 12.9342 28.1301 12.983C28.1301 14.4373 27.2502 15.2321 25.777 15.2321C24.8349 15.2321 24.1352 14.9821 23.5661 14.7787323.821 18 21.2429 15.0123 21.2429 15.6887C21.2429 16.7375 22.9072 17.6335 25.6622 17.6335ZM24.1317 9.27932C24.1317 7.94324 24.9928 7.09766 26.1024 7.09766C27.2119 7.09766 28.0918 7.94324 28.0918 9.27932C28.0918 1011.6 \ "/ \ u003e \ u003cpath d = \" M16.8045 11.9512C16.8045 13.2535 17.2637 13.8962 18.2965 13.8962C19.3298 13.8962 19.8079 13.2535 19.8079 11.9512V8.12928C19.8079 5.82936 18.4879 4.62866 14.379 4.6.66 .653 5.05154 11.6581 4.62866 10.3573 4.62866C9.34336 4.62866 8.57809 4.89931 7.9466 5.5079C7.58314 4.9328 7.10506 4.66232 6.51203 4.66232C5.47873 4.66232 5.00066 5.28821 5.00066 6.59049V11.95125.5566.56 .90741C8.0232 7.58817 8.44431 6.91179 9.53458 6.91179C10.5104 6.91179 10.893 7.58817 10.893 8.94108V11.9512C10.893 13.2535 11.3711 13.8962 12.4044 13.8962C13.4375 13.8962 13.915 7 13.2535 13.9157 11.9512V8.90741C13.9157 7.58817 14.3365 6.91179 15.4269 6.91179C16.4027 6.91179 16.8045 7.58817 16.8045 8.94108V11.9512Z \ "/ \ u003e \ u003cpath d = \" M3.31675 6.575493.366663.36 791758 4.66232 0.313354 5.28821 0.313354 6.59049V11.9512C0.313354 13.2535 0.791758 13.8962 1.82471 13.8962C2.85798 13.8962 3.31675 13.2535 3.31675 11.9512V6.59049Z \ "/ \ u003e \ u003cp1121 = 01.61 = 0.16 C0 2.87869 0.822846 3.57676 1.87209 3.57676C2.90056 3.57676 3.7234 2.87869 3.7234 1.98861C3.7234 1.1159 2.90056 0.400291 1.87209 0.400291Z \ "fill = \" # 1BB76E \ "/ \ u003e \ u003c / sv3 \ u00e \ u00e \ u00e,
contentPolicyHtml: "Brukerbidrag lisensiert under \ u003ca href = \" https: //stackoverflow.com/help/licensing \ "\ u003ecc by-sa \ u003c / a \ u003e \ u003ca href = \" https://stackoverflow.com / legal / content-policy \ "\ u003e (policy for innhold) \ u003c / a \ u003e",
allowUrls: sant
},
onDemand: sant,
discardSelector: ".discard-answer"
, umiddelbartShowMarkdownHelp: true, enableTables: true, enableSnippets: true
});
}
});
Takk for at du bidro med svaret på Stack Overflow!
Sørg for å svare på spørsmålet. Gi detaljer og del din forskning!
Men unngå ...
Be om hjelp, avklaring eller svare på andre svar.
Å komme med uttalelser basert på mening; sikkerhetskopier dem med referanser eller personlig erfaring.
For å lære mer, se tipsene våre for å skrive gode svar.
Utkast lagret
Utkast kastet
Registrer deg eller logg inn
StackExchange.ready (funksjon () {
StackExchange.helpers.onClickDraftSave ('# login-link');
});
Registrer deg ved hjelp av Google
Registrer deg ved hjelp av Facebook
Registrer deg ved hjelp av e-post og passord
Sende inn
Legg ut som gjest
Navn
E-post
Påkrevd, men aldri vist
StackExchange.ready (
funksjon () {
StackExchange.openid.initPostLogin ('. New-post-login', 'https% 3a% 2f% 2fstackoverflow.com% 2fquestions% 2f4423553% 2fdo-spaces-comments-slow-javascript-down% 23new-answer', 'question_page' );
}
);
Legg ut som gjest
Navn
E-post
Påkrevd, men aldri vist
Legg ut svaret ditt
Kast
Ved å klikke på “Legg ut svaret ditt” godtar du våre vilkår for bruk, personvernregler og policy for informasjonskapsler
Er ikke svaret du leter etter? Bla gjennom andre spørsmål merket javascript eller still ditt eget spørsmål.